<script setup lang="ts">
import type { Message } from '@/types/room'
import type { Image } from '@/types/consult'
import { IllnessTime, MsgType } from '@/enums'
import { timeOptions, flagOptions } from '@/api/constants'
import { showImagePreview } from 'vant'
import { useUserStore } from '@/stores'
import dayjs from 'dayjs'
defineProps<{
  list: Message[]
}>()
const { user } = useUserStore()
const getIllnessTimeText = (time?: IllnessTime) => timeOptions.find(item => item.value === time)?.text
const getConsultFlagText = (flag?: 0 | 1) => flagOptions.find(item => item.value === flag)?.text
const previewImg = (i: Image[]) => {
  showImagePreview(i.map(item => item.url))
}
const formatTime = (time: string) => dayjs(time).format('HH:mm')
</script>

<template>
  <div class="room-box" v-for="{ id, msg, msgType, from, createTime } in list" :key="id">
    <!-- 通用通知 -->
    <div class="msg msg-tip" v-if="msgType === MsgType.Notify">
      <div class="content">
        <span>{{ msg.content }}</span>
      </div>
    </div>
    <!-- 病情描述-->
    <div class="msg msg-illness" v-if="msgType === MsgType.CardPat">
      <div class="patient van-hairline--bottom">
        <p>
          {{ msg.consultRecord?.patientInfo.name }}
          {{ msg.consultRecord?.patientInfo.genderValue }}
          {{ msg.consultRecord?.patientInfo.age }}
        </p>
        <p>
          {{ getIllnessTimeText(msg.consultRecord?.illnessTime) }} |
          {{ getConsultFlagText(msg.consultRecord?.consultFlag) }}
        </p>
      </div>
      <van-row>
        <van-col span="6">病情描述</van-col>
        <van-col span="18">{{ msg.consultRecord?.illnessDesc }}</van-col>
        <template v-if="msg.consultRecord?.pictures.length !== 0">
          <van-col span="6">图片</van-col>
          <van-col span="18" @click="previewImg(msg.consultRecord?.pictures as Image[])"> 点击查看 </van-col>
        </template>
      </van-row>
    </div>
    <!-- 温馨提示 -->
    <div class="msg msg-tip" v-if="msgType === MsgType.NotifyTip">
      <div class="content">
        <span class="green">温馨提示：</span>
        <span>{{ msg.content }}</span>
      </div>
    </div>

    <!-- 发送文字 -->
    <div class="msg msg-to" v-if="msgType === MsgType.MsgText && user?.id === from">
      <div class="content">
        <div class="time">{{ formatTime(createTime) }}</div>
        <div class="pao">{{ msg.content }}</div>
      </div>
      <van-image :src="user?.avatar" />
    </div>

    <!-- 发送图片 -->
    <!-- <div class="msg msg-to">
      <div class="content">
        <div class="time">20:12</div>
        <van-image fit="contain" src="https://yjy-oss-files.oss-cn-zhangjiakou.aliyuncs.com/tuxian/popular_3.jpg" />
      </div>
      <van-image src="https://yjy-oss-files.oss-cn-zhangjiakou.aliyuncs.com/tuxian/popular_3.jpg" />
    </div> -->
    <!-- 接收文字 -->
    <div class="msg msg-from" v-if="msgType === MsgType.MsgText && from !== user?.id">
      <van-image src="https://yjy-oss-files.oss-cn-zhangjiakou.aliyuncs.com/tuxian/popular_3.jpg" />
      <div class="content">
        <div class="time">{{ formatTime(createTime) }}</div>
        <div class="pao">{{ msg.content }}</div>
      </div>
    </div>
    <!-- 处方消息 -->
    <!-- <div class="msg msg-recipe">
      <div class="content">
        <div class="head van-hairline--bottom">
          <div class="head-tit">
            <h3>电子处方</h3>
            <p>原始处方 <van-icon name="arrow"></van-icon></p>
          </div>
          <p>李富贵 男 31岁 血管性头痛</p>
          <p>开方时间:2022-01-15 14:21:42</p>
        </div>
        <div class="body">
          <div class="body-item" v-for="i in 2" :key="i">
            <div class="durg">
              <p>优赛明 维生素E乳</p>
              <p>口服,每次1袋,每天3次,用药3天</p>
            </div>
            <div class="num">x1</div>
          </div>
        </div>
        <div class="foot"><span>购买药品</span></div>
      </div>
    </div> -->
    <!-- 订单取消 -->
    <!-- <div class="msg msg-tip msg-tip-cancel">
      <div class="content">
        <span>订单取消</span>
      </div>
    </div> -->
  </div>
</template>

<style lang="scss" scoped>
@import '@/styles/room.scss';
</style>
